aboutsummaryrefslogtreecommitdiff
path: root/pages/api/v2/info/[id].js
diff options
context:
space:
mode:
authorFactiven <[email protected]>2023-09-13 00:45:53 +0700
committerGitHub <[email protected]>2023-09-13 00:45:53 +0700
commit7327a69b55a20b99b14ee0803d6cf5f8b88c45ef (patch)
treecbcca777593a8cc4b0282e7d85a6fc51ba517e25 /pages/api/v2/info/[id].js
parentUpdate issue templates (diff)
downloadmoopa-7327a69b55a20b99b14ee0803d6cf5f8b88c45ef.tar.xz
moopa-7327a69b55a20b99b14ee0803d6cf5f8b88c45ef.zip
Update v4 - Merge pre-push to main (#71)
* Create build-test.yml * initial v4 commit * update: github workflow * update: push on branch * Update .github/ISSUE_TEMPLATE/bug_report.md * configuring next.config.js file
Diffstat (limited to 'pages/api/v2/info/[id].js')
-rw-r--r--pages/api/v2/info/[id].js39
1 files changed, 39 insertions, 0 deletions
diff --git a/pages/api/v2/info/[id].js b/pages/api/v2/info/[id].js
new file mode 100644
index 0000000..41daa6e
--- /dev/null
+++ b/pages/api/v2/info/[id].js
@@ -0,0 +1,39 @@
+import axios from "axios";
+import redis from "../../../../lib/redis";
+
+const API_KEY = process.env.API_KEY;
+
+export async function fetchInfo(id) {
+ try {
+ const { data } = await axios.get(
+ `https://api.anify.tv/info/${id}?apikey=${API_KEY}`
+ );
+ return data;
+ } catch (error) {
+ console.error("Error fetching data:", error);
+ return null;
+ }
+}
+
+export default async function handler(req, res) {
+ const id = req.query.id;
+ let cached;
+ if (redis) {
+ cached = await redis.get(id);
+ }
+ if (cached) {
+ // console.log("Using cached data");
+ return res.status(200).json(JSON.parse(cached));
+ } else {
+ const data = await fetchInfo(id);
+ if (data) {
+ // console.log("Setting cache");
+ if (redis) {
+ await redis.set(id, JSON.stringify(data), "EX", 60 * 10);
+ }
+ return res.status(200).json(data);
+ } else {
+ return res.status(404).json({ message: "Schedule not found" });
+ }
+ }
+}